home *** CD-ROM | disk | FTP | other *** search
/ Speccy ClassiX 1998 / Speccy ClassiX 98.iso / amiga_system / the_aminet / dev / gcc / ixemulsrc.lha / ixemul-41.4 / network / ndbm.c < prev    next >
C/C++ Source or Header  |  1995-05-18  |  4KB  |  195 lines

  1. /*-
  2.  * Copyright (c) 1990 The Regents of the University of California.
  3.  * All rights reserved.
  4.  *
  5.  * This code is derived from software contributed to Berkeley by
  6.  * Margo Seltzer.
  7.  *
  8.  * Redistribution and use in source and binary forms, with or without
  9.  * modification, are permitted provided that the following conditions
  10.  * are met:
  11.  * 1. Redistributions of source code must retain the above copyright
  12.  *    notice, this list of conditions and the following disclaimer.
  13.  * 2. Redistributions in binary form must reproduce the above copyright
  14.  *    notice, this list of conditions and the following disclaimer in the
  15.  *    documentation and/or other materials provided with the distribution.
  16.  * 3. All advertising materials mentioning features or use of this software
  17.  *    must display the following acknowledgement:
  18.  *    This product includes software developed by the University of
  19.  *    California, Berkeley and its contributors.
  20.  * 4. Neither the name of the University nor the names of its contributors
  21.  *    may be used to endorse or promote products derived from this software
  22.  *    without specific prior written permission.
  23.  *
  24.  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  25.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  26.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  27.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  28.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  29.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  30.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  31.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  32.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  33.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  34.  * SUCH DAMAGE.
  35.  */
  36.  
  37. #if defined(LIBC_SCCS) && !defined(lint)
  38. static char sccsid[] = "@(#)ndbm.c    5.7 (Berkeley) 6/17/91";
  39. #endif /* LIBC_SCCS and not lint */
  40.  
  41. /*
  42.     This package provides a dbm compatible interface to the new hashing
  43.     package described in db(3)
  44. */
  45.  
  46. #include <sys/param.h>
  47. #include <ndbm.h>
  48. #include <db.h>
  49. #include <stdio.h>
  50. #include "hash.h"
  51.  
  52. /*
  53.     return     *DBM on success
  54.         NULL on failure
  55. */
  56. extern DBM *
  57. dbm_open( file, flags, mode )
  58. const char     *file;
  59. int    flags;
  60. int    mode;
  61. {
  62.     HASHINFO    info;
  63.     char path[MAXPATHLEN];
  64.  
  65.     info.bsize = 1024;
  66.     info.ffactor = 5;
  67.     info.nelem = 1;
  68.     info.cachesize = NULL;
  69.     info.hash = NULL;
  70.     info.lorder = 0;
  71.     (void)strcpy(path, file);
  72.     (void)strcat(path, DBM_SUFFIX);
  73.     return( hash_open ( path, flags, mode, &info ) );
  74. }
  75.  
  76. extern void 
  77. dbm_close(db)
  78. DBM    *db;
  79. {
  80.     (void)(db->close) (db);
  81. }
  82.  
  83. /*
  84.     Returns     DATUM on success
  85.         NULL on failure
  86. */
  87. extern datum 
  88. dbm_fetch( db, key )
  89. DBM     *db;
  90. datum    key;
  91. {
  92.     int    status;
  93.     datum    retval;
  94.  
  95.     status = (db->get) ( db, (DBT *)&key, (DBT *)&retval, 0 );
  96.     if ( status ) {
  97.     retval.dptr = NULL;
  98.     retval.dsize = 0;
  99.     }
  100.     return(retval);
  101. }
  102.  
  103. /*
  104.     Returns     DATUM on success
  105.         NULL on failure
  106. */
  107. extern datum 
  108. dbm_firstkey(db)
  109. DBM     *db;
  110. {
  111.     int    status;
  112.     datum    retkey;
  113.     datum    retdata;
  114.  
  115.     status = (db->seq) ( db, (DBT *)&retkey, (DBT *)&retdata, R_FIRST );
  116.     if ( status ) {
  117.     retkey.dptr = NULL;
  118.     }
  119.     return(retkey);
  120. }
  121. /*
  122.     Returns     DATUM on success
  123.         NULL on failure
  124. */
  125. extern datum 
  126. dbm_nextkey(db)
  127. DBM     *db;
  128. {
  129.     int    status;
  130.     datum    retkey;
  131.     datum    retdata;
  132.  
  133.     status = (db->seq) ( db, (DBT *)&retkey, (DBT *)&retdata, R_NEXT );
  134.     if ( status ) {
  135.     retkey.dptr = NULL;
  136.     }
  137.     return(retkey);
  138. }
  139.  
  140. /*
  141.     0 on success
  142.     <0 failure
  143. */
  144. extern int 
  145. dbm_delete(db, key)
  146. DBM     *db;
  147. datum    key;
  148. {
  149.     int    status;
  150.  
  151.     status = (db->del)( db, (DBT *)&key, 0 );
  152.     if ( status ) {
  153.     return(-1);
  154.     } else {
  155.     return(0);
  156.     }
  157. }
  158.  
  159. /*
  160.     0 on success
  161.     <0 failure
  162.     1 if DBM_INSERT and entry exists
  163. */
  164. extern int 
  165. dbm_store(db, key, content, flags)
  166. DBM     *db;
  167. datum    key;
  168. datum    content;
  169. int    flags;
  170. {
  171.     return ((db->put)( db, (DBT *)&key, (DBT *)&content, 
  172.             (flags == DBM_INSERT) ? R_NOOVERWRITE : 0 ));
  173. }
  174.  
  175. extern int
  176. dbm_error(db)
  177. DBM    *db;
  178. {
  179.     HTAB    *hp;
  180.  
  181.     hp = (HTAB *)db->internal;
  182.     return ( hp->errno );
  183. }
  184.  
  185. extern int
  186. dbm_clearerr(db)
  187. DBM    *db;
  188. {
  189.     HTAB    *hp;
  190.  
  191.     hp = (HTAB *)db->internal;
  192.     hp->errno = 0;
  193.     return ( 0 );
  194. }
  195.